package cn.exrick.xboot.modules.subsystemNews.serviceimpl;

import cn.exrick.xboot.modules.subsystemNews.dao.mapper.SubsystemNewsMapper;
import cn.exrick.xboot.modules.subsystemNews.entity.SubsystemNews;
import cn.exrick.xboot.modules.subsystemNews.service.ISubsystemNewsService;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.annotations.Param;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * 子系统新闻接口实现
 * @author Exrick
 */
@Slf4j
@Service
@Transactional
public class ISubsystemNewsServiceImpl extends ServiceImpl<SubsystemNewsMapper, SubsystemNews> implements ISubsystemNewsService {

    @Autowired
    private SubsystemNewsMapper subsystemNewsMapper;

    /**
     * 20190719
     * njp
     * 新增分页的条件查询（此方法以xml格式文件映射sql语句，本人认为这样做更灵活）
     * 目前只接收一个参数
     */
    @Override
    public IPage<SubsystemNews> selectPageVo(Page page, @Param("title")  String title){
        return subsystemNewsMapper.selectPageVo(page,title);
    }
    @Override
    public IPage<SubsystemNews> selectPageVoMap(Page page,@Param("map") Map<String,Object> map){
        return subsystemNewsMapper.selectPageVoMap(page,map);
    }
    /**
     * 20190722
     * njp
     * 新增公告分页的条件查询(使用map作为条件的载体)（此方法以xml格式文件映射sql语句，本人认为这样做更灵活）
     * map 为参数
     */
    @Override
    public IPage<SubsystemNews> selectNoticePageVoMap(Page page, @Param("map") Map<String,Object> map){
        return subsystemNewsMapper.selectNoticePageVoMap(page,map);
    }

    /**
     * 20190729
     * njp
     * 新增公告的portal页数据查询
     * map 为参数
     */
    @Override
    public List<Object> selectNoticePortal(@Param("map") Map<String,Object> map){
        return subsystemNewsMapper.selectNoticePortal(map);
    }

    /**
     * 查询指定数量的数据
     * @param map
     * @return
     */
    @Override
    public List<SubsystemNews> selectNewsByNum(@Param("map") Map<String,Object> map){
        return subsystemNewsMapper.selectNewsByNum(map);
    }

    /**
     * 20200103
     * njp
     * 新增公告分页的条件查询(使用map作为条件的载体)返回值中有单点地址
     * map 为参数
     */
    @Override
    public IPage<SubsystemNews> selectPortalNoticePageVoMap(Page page, @Param("map") Map<String,Object> map){
        return subsystemNewsMapper.selectPortalNoticePageVoMap(page,map);
    }
}